package com.zrf.base.knowledge.leetcode.editor.cn;

/**
 * //给定一个非负整数数组，你最初位于数组的第一个位置。
 * //
 * // 数组中的每个元素代表你在该位置可以跳跃的最大长度。
 * //
 * // 判断你是否能够到达最后一个位置。
 * //
 * // 示例 1:
 * //
 * // 输入: [2,3,1,1,4]
 * //输出: true
 * //解释: 我们可以先跳 1 步，从位置 0 到达 位置 1, 然后再从位置 1 跳 3 步到达最后一个位置。
 * //
 * //
 * // 示例 2:
 * //
 * // 输入: [3,2,1,0,4]
 * //输出: false
 * //解释: 无论怎样，你总会到达索引为 3 的位置。但该位置的最大跳跃长度是 0 ， 所以你永远不可能到达最后一个位置。
 * //
 * // Related Topics 贪心算法 数组
 * // 👍 918 👎 0
 *
 * @author zhouruifeng
 * @date 2020-11-13 07:37:21
 */
public class JumpGame {
    public static void main(String[] args) {
        Solution solution = new JumpGame().new Solution();
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public boolean canJump(int[] nums) {
            int maxJump = 0;
            for (int i = 0; i < nums.length; i++) {
                if (i <= maxJump) {
                    maxJump = Math.max(maxJump, i + nums[i]);
                    if (maxJump >= nums.length - 1) {
                        return true;
                    }
                }
            }
            return false;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}